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(54) Hand held ultrasonic diagnostic instrument 

(57) A hand held ultrasonic instrument is provided 
in a portable unit which performs both B mode and Dop- 
pler imaging. In a preferred embodiment an array trans- 



ducer, digital beamformer, digital filter, and image proc- 
essor are packaged in one or more enclosures weighing 
ten pounds (4.5 kilograms) or less. 
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Description 

This invention relates to medical ultrasonic diagnostic systems and, in particular, to a fully integrated hand held 
ultrasonic diagnostic instrument. 

As is well known, modern ultrasonic diagnostic systems are large, complex instruments. Today's premium ultra- 
sound systems, while mounted in carts for portability, continue to weigh several hundred pounds. In the past, ultrasound 
systems such as the ADR 4000 ultrasound system produced by Advanced Technology Laboratories, Inc., assignee of 
the present invention, were smaller, desktop units about the size of a personal computer. However, such instruments 
lacked many of the advanced features of today's premium ultrasound systems such as color Doppler imaging and 
three dimensional display capabilities. As ultrasound systems have become more sophisticated they have also become 
bulkier. 

However, with the ever increasing density of digital electronics, it is now possible to foresee a time when ultrasound 
systems will be able to be miniaturized to a size even smaller than their much earlier ancestors. The physician is 
accustomed to working with a hand held ultrasonic scanhead which is about the size of an electric razor. It would be 
desirable, consistent with the familiar scanhead, to be able to compact the entire ultrasound system into a scanhead- 
sized unit. It would be further desirable for such an ultrasound instrument to retain as many of the features of today's 
sophisticated ultrasound systems as possible, such as speckle reduction, color Doppler and three dimensional imaging 
capabilities. 

In accordance with the principles of the present invention, a diagnostic ultrasound instrument is provided which 
exhibits many of the features of a premium ultrasound system in a hand held unit. The instrument can be produced as 
a single unit or, in a preferred embodiment, the instrument is a two-part unit, one including a transducer, beamformer, 
and image processor and the other including a display and power source for both units. In such a configuration the 
transducer/processor unit can be manipulated with one hand while a cable between the two units enables the video 
to be shown on the display unit while the latter unit is held or positioned for optimal viewing of the ultrasound image. 
The cable also provides energy for the transducer/processor unit from the display unit. 

In a preferred embodiment the ultrasound system, from the transducer through to a video output, is fabricated on 
four types of application specific integrated circuits (ASICs): a transmit/receive ASIC which is connected to the elements 
of an array transducer, a front end ASIC which performs and controls transmit and receive beamforming, a digital signal 
processing ASIC which provides processing of the ultrasound signals such as filtering, and a back end ASIC which 
receives processed ultrasound signals and produces ultrasound image data. The image can be displayed on either a 
standard monitor or on a liquid crystal display (LCD). Comprised as it is of ASICs, the electronics of the unit can be 
fabricated on a single printed circuit board, eliminating the problems conventionally posed by connectors and cables. 
This sophisticated ultrasound instrument can be manufactured as a hand held unit weighing less than five pounds. 

In the drawings: 

FIGURE 1 illustrates in block diagram form the architecture of a hand-held ultrasound system of the present in- 
vention; 

FIGURES 2a and 2b are front and side views of a hand-held ultrasound system of the present invention which is 
packaged as a single unit; 

FIGURES 3a and 3b are front and side views of the transducer unit of a two-unit hand-held ultrasound system of 
the present invention; 

FIGURE 4 illustrates the two units of a hand-held ultrasound system of the present invention in a two-unit package; 

FIGURE 5 is a schematic diagram of the transmit/receive ASIC of the ultrasound system of FIGURE 1; 

FIGURE 6 is a block diagram of the front end ASIC of the ultrasound system of FIGURE 1; 

FIGURE 7 illustrates the aperture control afforded by the transmit/receive and front end ASICs; 

FIGURE 8 is a block diagram of the digital signal processing ASIC of the ultrasound system of FIGURE 1 ; 

FIGURE 9 illustrates a min-max filter for flash suppression; 

FIGURE 10a-10c are waveforms illustrating the operation of the flash suppression processor; 
FIGURE 11 is a flowchart of B mode processing by the digital signal processing ASIC; 
FIGURE 1 2 is a flowchart of Doppler processing by the digital signal processing ASIC; 
FIGURE 1 3 is a block diagram of the back end ASIC of the ultrasound system of FIGURE 1 ; 
FIGURE 14 illustrates R9 scan conversion in accordance with the present invention; 
FIGURE 15 illustrates scanline interpolation by the scan converter; 

FIGURE 16 is a further illustration of scan conversion in accordance with the present invention; 
FIGURE 17a and 17b illustrate combined B mode and Doppler images; 
FIGURE 18 illustrates combined B mode and Doppler scanlines; 

FIGURES 19 and 20 illustrate three dimensional rendering using two dimensional image frames; 
FIGURE 21 illustrates the partitioning of the frame buffer memory during three dimensional imaging; and 
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FIGURE 22 is a chart of the user controls of the ultrasound system of FIGURE 1 . 

Referring first to FIGURE 1, the architecture of a hand-held ultrasound system of the present invention is shown. 
It is possible to package an entire ultrasound system in a single hand-held unit only through judicious selection of 
functions and features and efficient use of integrated circuit and ultrasound technology. A transducer array 10 is used 
for its solid state, electronic control capabilities, variable aperture, image performance and reliability. Either a flat or 
curved linear array can be used. In a preferred embodiment the array is a curved array, which affords a broad sector 
scanning field. While the preferred embodiment provides sufficient delay capability to both steer and focus a flat array 
such as a phased array, the geometric curvature of the curved array reduces the delay requirements on the beamformer. 
The elements of the array are connected to a transmit/receive ASIC 20 which drives the transducer elements and 
receives echoes received by the elements. The transmit/receive ASIC 30 also controls the transmit and receive aper- 
tures of the array 10 and the gain of the received echo signals. The transmit/receive ASIC is preferably located within 
inches of the transducer elements, preferably in the same enclosure, and just behind the transducer. 

Echoes received by the transmit/receive ASIC 20 are provided to the adjacent front end ASIC 30 : which beamforms 
the echoes from the individual transducer elements into scanline signals. The front end ASIC 30 also controls the 
transmit waveform, timing, aperture and focusing. In the illustrated embodiment the front end ASIC 30 provides timing 
signals for the other ASICs, time gain control, and monitors and controls the power applied to the transducer array, 
thereby controlling the acoustic energy which is applied to the patient and minimizing power consumption of the unit. 
A memory device 32 is connected to the front end ASIC 30, which stores data used by the beamformer. 

Beamformed scanline signals are coupled from the front end ASIC 30 to the adjacent digital signal processing 
ASIC 40. The digital signal processing ASIC 40 filters the scanline signals and in the preferred embodiment also pro- 
vides several advanced features including synthetic aperture formation, frequency compounding, Doppler processing 
such as power Doppler (color power angio) processing, and speckle reduction. 

The ultrasound B mode and Doppler information is then coupled to the adjacent back end ASIC 50 for scan con- 
version and the production of video output signals. A memory device 42 is coupled to the back end ASIC 50 to provide 
storage used in three dimensional power Doppler (3D CPA) imaging. The back end ASIC also adds alphanumeric 
information to the display such as the time, date, and patient identification. A graphics processor overlays the ultrasound 
image with information such as depth and focus markers and cursors. Frames of ultrasonic images are stored in a 
video memory 54 coupled to the back end ASIC 50 : enabling them to be recalled and replayed in a live Cineloop® 
realtime sequence. Video information is available at a video output in several formats, including NTSC and PAL tele- 
vision formats and RGB drive signals for an LCD display 60 or a video monitor. 

The back end ASIC 50 also includes the central processor for the ultrasound system, a RISC (reduced instruction 
set controller) processor The RISC processor is coupled to the front end and digital signal processing ASICs to control 
and synchronize the processing and control functions throughout the hand-held unit. A program memory 52 is coupled 
to the back end ASIC 50 to store program data which is used by the RISC processor to operate and control the unit. 
The back end ASIC 50 is also coupled to a data port configured as a PCMCIA interface 56. This interface allows other 
modules and functions to be attached to the hand-held ultrasound unit. The interface 56 can connect to a modem or 
communications link to transmit and receive ultrasound information from remote locations. The interface can accept 
other data storage devices to add new functionality to the unit, such as an ultrasound information analysis package. 

The RISC processor is also coupled to the user controls 70 of the unit to accept user inputs to direct and control 
the operations of the hand-held ultrasound system. 

Power for the hand-held ultrasound system in a preferred embodiment is provided by a rechargeable battery. 
Battery power is conserved and applied to the components of the unit from a power subsystem 80. The power sub- 
system 80 includes a DC converter to convert the low battery voltage to a higher voltage which is applied to the transmit/ 
receive ASIC 20 to drive the elements of the transducer array 10. 

FIGURES 2a and 2b illustrate a one piece unit 80 for housing the ultrasound system of FIGURE 1 . The front of 
the unit is shown in FIGURE 2a, including an upper section 83 which includes the LCD display 60. The lower section 
81 includes the user controls as indicated at 86. The user controls enable the user to turn the unit on and off, select 
operating characteristics such as the mode (B mode or Doppler), color Doppler sector or frame rate, and special func- 
tions such as three dimensional display. The user controls also enable entry of time, date, and patient data. A four way 
control, shown as a cross, operates as a joystick to maneuver cursors on the screen or select functions from a user 
menu. Alternatively a mouse ball or track pad can be used to provide cursor and other controls in multiple directions. 
Several buttons and switches of the controls are dedicated for specific functions such as freezing an image and storing 
and replaying an image sequence from the Cineloop memory. 

At the bottom of the unit 80 is the aperture 84 of the curved transducer array 10. In use, the transducer aperture 
is held against the patient to scan the patient and the ultrasound image is displayed on the LCD display 60. 

FIGURE 2b is a side view of the unit 80, showing the depth of the unit. The unit is approximately 20.3 cm high, 
11.4 cm wide, and 4.5 cm deep. This unit contains all of the elements of a fully operational ultrasound system with a 
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curved array transducer probe, in a single package weighing less than five pounds. A major portion of this weight is 
attributable to the battery housed inside the unit. 

FIGURES 3 and 4 illustrate a second packaging configuration in which the ultrasound system is housed in two 
separate sections. A lower section 81 includes the transducer array the electronics through to a video signal output, 

s and the user controls. This lower section is shown in FIGURE 3a, with the curved transducer array aperture visible at 
the bottom. The lower section is shown in the side view of FIGURE 3b. This lower section measures about 11.4 cm 
high by 9.3 cm wide by 2.5 cm deep. This unit has approximately the same weight as a conventional ultrasound scan- 
head. This lower section is connected to an upper section 83 as shown in FIGURE 4 by a cable 90. The upper section 
83 includes an LCD display 82 and a battery pack 88. The cable 90 couples video signals from the lower unit 81 to the 

10 upper unit for display, and provides power for the lower unit from the battery pack 88. This two part unit is advantageous 
because the user can maneuver the lower unit and the transducer 84 over the patient in the manner of a conventional 
scanhead, while holding the upper unit in a convenient stationary position for viewing. By locating the battery pack in 
the upper unit, the lower unit is lightened and easily maneuverable over the body of the patient. 

Other system packaging configurations will be readily apparent. For instance, the front end ASIC 30, the digital 

is signal processing ASIC 40, and the back end ASIC 50 could be located in a common encbsure, with the beamformer 
of the front end ASIC connectable to different array transducers. This would enable different transducers to be used 
with the digital beamformer, digital filter, and image processor for different diagnostic imaging procedures. A display 
could be located in the same enclosure as the three ASICS, or the output of the back end ASIC could be connected 
to a separate display device. 

20 Referring now to FIGURE 5, the transmit/receive ASIC 20 is shown in greater detail. This ASIC is comprised of 

sixteen sections, each of which is coupled to six transducer elements of the array 10. The illustrated section 20a is 
coupled to elements 1, 17, 33, 49, 65 and 81 at the terminals on the left side of the drawing. With six elements per 
section, the entire ASIC can operate with a 96 element transducer. Each section could be configured to operate with 
eight elements, in which case the ASIC could control a 1 28 element transducer, for instance. Prior to the transmission 

25 of an ultrasonic pulse for a scanline, a serial stream of data from the front end ASIC 30 is clocked into transmit aperture 
select logic 206 at the Transmit Data In and Clk terminals at the right side of the drawing. The transmit aperture select 
logic 206 uses this data to set multiplexer switches in 3:1 transmit muxes 208 and 210 for the transducer elements 
that will be active for the particular scanline. For instance, the next scanline to be transmitted may have a transmit 
aperture comprising elements 1-32. This requires that transmit mux 208 closes a switch to connect pulser 202 to the 

30 element 1 terminal, and the transmit mux 210 closes a switch to connect pulser 204 to the element 17 terminal. In a 
similar manner the transmit muxes in the other fifteen sections of the ASIC will connect pulsers to element terminals 
2-16 and 18-32. 

At the times when the connected elements 1 and 1 7 are to be activated, drive signals for the pulsers 202 and 204 
are applied to the Signal 1 In and Signal 2 In terminals by the front end ASIC. For unipolar pulsers the drive signals 

35 may be applied to these terminals, then the pulsers are enabled at the appropriate times by signals applied to the 
enable 1 and enable 2 terminals. Alternatively, complementary waveforms are applied at the appropriate times to the 
paired terminals. These drive signals are applied as logic level signals to the pulser inputs, then converted to high 
voltage driving waveforms by the application of high voltage HV applied to the muxes 208 and 210. It is also possible 
to fabricate the pulser and mux functions as a single unit, whereby each switch of the muxes is effectively a high voltage 

40 pulser. Stated another way, this means that each mux would comprise three separately controlled pulsers. Alternatively, 
the two pulsers at the inputs of the transmit muxes could be deleted and replaced by six pulsers at the outputs of the 
transmit muxes, however, the illustrated embodiment advantageously requires only two, low voltage pulsers. Continuing 
with the example of the aperture of elements 1-32, if element 1 is at the periphery of the aperture and element 17 is 
more central to the aperture, element 1 would be pulsed earlier in time than element 1 7 to produce a focused transmitted 

45 ultrasonic waveform. 

Prior to transmission of the scanline a stream of digital data from the front end ASIC is clocked into receive aperture 
select logic 214 from the Receive Data In and Clk terminals connected to logic 214. The receive aperture select logic 
closes switches in a 6:1 receive mux 212 and a 1 :8 receive mux 218 for the proper receive aperture. Like the transmit 
aperture select bgic, the receive aperture select logic includes buffer storage so that data for the next scanline can be 

so received while the ASIC is receiving echoes from the current scanline. The illustrated embodiment is designed for a 
sixteen element folded receive aperture as shown by the eight data bus tines at the output of the 1 :8 receive mux 218. 
The inputs to the 6:1 receive mux 212 are connected to the six element terminals for section 201 and are protected 
from the high drive voltages by the integration of transmit/receive networks at the mux inputs. The receive aperture 
select logic 21 4 connects one of the inputs of the mux 21 2 to the mux output, and the received signal from the selected 

55 element is applied to a first time gain control (TGC) amplifier 216. The gain of this TGC amplifier is controlled by a 
control signal applied to a TGC Control terminal of the ASIC. The amplification provided by amplifier 216 increases as 
ultrasonic echoes are received from increasing depths, in the conventional manner. The amplified echo signals are 
then coupled by the switching of the 1 :8 receive mux 218 to one of the data bus lines 220. 
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Each of the data bus lines 220 is coupled to the same corresponding output of every 1 :8 receive mux on the ASIC. 
The outputs of the mux 218 are numbered from 1-8. Output 1 of each 1:8 receive mux is coupled to the same one of 
the data lines; output 2 of each 1 :8 receive mux is coupled to another one of the data lines; and so forth. The preferred 
embodiment system uses a sixteen element folded aperture of scanlines transmitted orthogonal to the transducer. This 

5 means that two elements of the aperture will have the same receive phases of operation; the sixteen elements of the 
receive aperture will be paired to have eight' receive phases. For instance, if the received scanline is located at the 
center of an aperture of elements 1-16, elements 1 and 16 will have the same receive timing: Echoes received by 
element 1 will be connected through mux 212, amplified by TGC amplifier 216, connected through mux 218 and pro- 
duced as a current output at output 8 of the mux 218. At the same time, an echo received by element 16 will be 

10 connected through the muxes of another section of the ASIC, identically amplified by another TGC amplifier, and 
produced as a current output at output 8 of another 1:8 receive mux. These two currents are identically phased by 
virtue of the folded aperture, and combine on the data line which is coupled to output 8 of the receive muxes. 

The currents on each data line are filtered and converted to voltages by a filter network such as that shown at 222. 
I n the preferred embodiment filter network 222 is external to and coupled to a terminal of the ASIC so that its components 

15 and hence its filter characteristic can be easily selected and changed. The filter characteristic is a bandpass chosen 
to match the passband of the transducer. For a 3.5 MHz transducer the passband could extend from 1 .5 to 5.5 MHz, 
for example. The filter is connected to a current source through the filter impedance to convert the current signals to 
a single voltage. This voltage reenters the ASIC through another (or the same) ASIC terminal and is applied to the 
input of a second TGC amplifier 224. The use of two TGC amplifiers enables operation over the wide dynamic range 

20 of the two cascaded amplifiers. In the illustrated embodiment a single TGC Control applies the same control charac- 
teristic to both TGC amplifiers 216 and 224, but it is also possible to apply separate and different TGC characteristics 
to the two amplifiers. The amplified echo signals are brought to a final output terminal of the ASIC where they are 
filtered by a bandpass filter 226 and coupled to an analog to digital (A/D) converter at the input of the beamformer on 
the front end ASIC. 

25 The separate sections of the transmit/receive ASIC 20 may be contained in separate ASICs or combined so that 

several sections are integrated on the same ASIC. Preferably all sixteen sections are integrated onto a single ASIC chip. 

Thus it is seen that, in the preferred embodiment, the transmit/receive ASIC 20 operates with a 96 element trans- 
ducer array, and uses a 32 element transmit aperture and a 16 element folded receive aperture. With the use of a 
synthetic aperture as discussed below, the system exhibits a 32 element aperture on both transmit and receive. 

so Details of the front end ASIC 30 are shown in FIGURE 6. This drawing shows one section 30a of the front end 

ASIC 30. There are eight such sections on the front end ASIC to provide beamforming of the eight outputs from the 
transmit/receive ASIC 20. Each echo signal output is coupled to the input ot an A/D converter 310, where the echo 
signals are converted to digital data. The digital data from each element (or each pair of elements in a folded aperture) 
is shifted into a first in, first out (FIFO) register 312 by a clock signal A/D CLK. The A/D CLK signal is provided by a 

35 dynamic focus timing circuit 31 4 which defers the start of the clock signal to provide an initial delay, then controls the 
signal sampling times to provide dynamic focusing of the received echo signals. The length of the FIFO register 312 
is determined by the initial delay, the transducer center frequency, the aperture size, the curvature of the array, and 
the beam steering requirement. A higher center frequency and a curved array will reduce the delay requirement and 
hence the length of the FIFO register, for instance. The delayed echo signals from the FIFO register 312 are coupled 

40 to a multiplier 316 where the echo signals are weighted by dynamic weight values stored in a dynamic weight register 
318. The dynamic weight values weight the echo signals to normalize the echo information in consideration of the 
effects of a dynamic receive aperture, which expands by the inclusion of additional outer elements as echoes are 
received from increasing depths along the scanline. The delayed and weighted echo signals are then summed with 
appropriately delayed and weighted echo signals from other elements and echo signals from any other delay stages 

^5 which are coupled in cascade by a summing circuit 320. The beamformed echo signals, together with synchronous 
overflow bits, are produced as output scanline data on an RF data bus. Accompanying each sequence of scanline 
echo signals is identifying information provided by an RF header sequencer on the ASIC, which identifies the type of 
scanline data being produced. The RF header can identify the scanline as B mode echo data or Doppler data, for 
instance. 

50 Other digital storage devices can be used to provide the beamformer delays, if desired. A dual ported random 

access memory can be used to store the received digital echo samples, which are then read out from the memory at 
times or sequences which provide the desired delay for the signals from the transducer elements. 

Each section 30a of the front end ASIC includes transmit control circuits 302-308 for four transducer elements of 
the array. The eight sections thus provide transmit control for 32 elements of the array at the same time, thereby 
55 determining the maximum transmit aperture. The transmit control circuits produce waveforms at the desired transmis- 
sion frequency, and enable signals which activate the pulsers at the appropriate times to produce a transmitted acoustic 
signal which is focused at the desired depth of focus. 

The front end ASIC includes a common control section 330 which provides overall control for the transmission and 
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receive functions. The control section 330 is controlled by and receives data under control of the RISC processor 
located on the back end ASIC. The data tables lor a particular image frame are stored in random access memory 
(RAM) 32 and are loaded into the control section 330 under command of the RISC processor. The control section 330 
includes a number of sequencers for the sequence of transmit and receive functions. The frame sequencer 332 pro- 
5 duces information used by other sequencers which identifies the type of image frame which is to be produced. The 
frame sequencer may, for example, be loaded with data that defines the next frame as B mode scanlines interspersed 
between groups of four Doppler scanlines, and that the sequence of scanlines will be all odd numbered scanlines 
followed by all even numbered scanlines. This information is supplied to the line sequencer 334, which controls the 
scanlines which are transmitted and received in the proper sequence. In preparation for a new scanline the line se- 
10 quencer controls the TGC sequencer 336 so that it will produce the desired sequence of TGC control data. The TGC 
control data from the TGC sequencer is converted to a voltage signal by a digital to analog converter (DAC) 338 and 
applied to the TGC Control input terminal(s) of the transmit/receive ASIC 20. The line sequencer 334 also controls the 
serial bus sequencer 340, which produces serial data on a serial bus for the transmit and receive aperture select logic 
circuits 206 and 214 on the transmit/receive ASIC. The receive/transmit (RT) register loader 342 controls the loading 
is of data for a new scanline into various registers on both ASICs, including the aperture select logic circuits 206 and 
214, the transmit control circuits 302-308, the dynamic focus timing circuit 314 and the dynamic weight register 318. 
All registers which perform real time functions are double buffered. As discussed above, the various registers are 
buffered so that the control data can be put on the serial bus and loaded into the various registers during the line 
preceding the scanline for which the control data is used. 
20 The front end ASIC 30 includes a current monitor circuit 346, which samples the current on the HV bus by way of 

an A/D converter 348. The current monitor assures patient safety by reducing or completely shutting down the high 
voltage supply if excessive current levels are detected, thereby protecting the patient from an overheated transducer 
or unacceptably high acoustic output levels. 

The front end ASIC includes in its control section a clock generator 350 which produces a plurality of synchronous 
25 clock signals from which all operations of the system are synchronized. To prevent interference and crosstalk among 
the closely spaced devices of the system, the scanline transmission frequency is synchronized to the video output 
signal frequency, so harmonics of one frequency will not produce interfering components in the other. A crystal oscillator 
(not shown) is coupled to the front end ASIC 30 to provide a basic high frequency such as 60 MHz from which all of 
the clock signals o1 the system may be derived. 
30 The operation of the transmit/receive and front end ASI Cs 20 and 30 to produce a synthetic folded aperture scanline 

from 32 elements of a curved array is illustrated with reference to FIGURE 7. In this drawing the ASICs are controlling 
an aperture of the transducer comprising 32 elements numbered from 25 through 32, then 1 through 24 of the curved 
array 10. Gathering the full aperture of scanline information requires two transmit sequences of all 32 elements. To 
transmit, the line sequencer 334, the serial bus sequencer 340, and the RT register loader 342 load the proper transmit 
35 mux data into the sixteen transmit aperture select logic circuits 206 and the 32 transmit controllers on the front end 
ASIC. The aperture select logic then control the 32 transmit muxes to connect pulsers to elements numbered 25-32 
and 1-24, the desired transmit aperture. The pulsers are pulsed by the transmit control circuits so as to produce an 
acoustic wave which is focused at point F in FIGURE 7. 

Following the first pulse transmission, echoes are received by the center group of elements numbered 1 -16, which 
40 at that time are connected by the sixteen 6:1 receive muxes and 1:8 receive muxes to eight output data lines. The 
sixteen receive signals are shown as separate when they pass through the initial TGC amplifiers, eight of which are 
shown in a row as indicated at 216' in FIGURE 7. The like phased signals are then seen to combine in pairs by virtue 
of the folded aperture where pairs of lines come together at the input of the beamformer delay lines, four of which are 
shown as indicated at 370. In the illustrated example the scanline 360 extends from the center of the array aperture 
45 between elements 8 and 9. This means that echo signals received by elements 8 and 9 will be in phase, and can be 
combined. Likewise, echoes received by paired elements 7 and 10, paired elements 6 and 11, and paired elements 5 
and 1 2 can also be combined. Thus, following the first transmitted pulse, echoes received by elements 1 -1 6 are delayed 
by the eight delay FIFOs and summed by the summing circuit 320. This half aperture is then stored for receipt of the 
other half aperture. 

50 Another acoustic pulse is transmitted by all 32 elements of the aperture. After this second pulse, the receive muxes 

now connect echoes from elements 25-32 and 17- 24 to the beamformer. By virtue of the folded aperture symmetry 
the echoes from element 32 are paired with echoes from element 1 7 and the two are combined. Likewise, echoes from 
element 31 are paired with echoes from element 18, and so forth, out to the most lateral paired elements 25 and 24. 
The sixteen received echoes, paired to eight signals by the folded aperture, are appropriately delayed by the eight 

55 delay FIFOs and summed to form a second half aperture of the scanline. The two halves of the aperture are now 
summed as a function of the location of the echo components along the scanline of the two sequences. Thus, the 
complete aperture has been formed by combining the separate receptions of echoes from the inner sixteen elements 
of the aperture, then from the outer sixteen elements. A precisely beamformed synthetic aperture signal is produced 
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by maintaining identical conditions of TGC control during both reception intervals. The dynamic weighting and dynamic 
focusing affect the two reception sequences differently by reason of the differing aperture locations of the receiving 
elements during the two sequences. The delays applied by the FIFOs during the two sequences will be different by 
reason of the differing locations across the aperture of the receiving elements from one sequence to the next. 

5 Referring to FIGURE 8, a block diagram of the digital signal processing ASIC 40 is shown. Scanline signals from 

the front end ASIC 30 are received by a normalization circuit, where they are multiplied by a variable coefficient supplied 
by coefficient memory 408 to normalize the received signals for aperture variation. When the transducer is receiving 
signals along the scanline from shallow depths, a relatively small aperture, such as four or eight transducer elements, 
is used to receive echo signals. As the reception depth along the scanline increases, the aperture is incrementally 

10 increased so that the full 32 element aperture is used at maximum depths. The normalization circuit will multiply the 
received scanline signals by appropriate coefficients over the range of aperture variation, such as factors of four or 
eight, to normalize the signals for this aperture variation effect. 

When the ultrasound system is operated in the B mode to form a structural image of tissue and organs, the digital 
signal processor is operated as shown by the flowchart of FIGURE 11 . The normalized echo signals follow two paths 

15 in FIGURE 8, one of which is coupled to a four multiplier filter 412 and the other of which is coupled by a multiplexer 
422 to a second four multiplier filter 414. Each multiplier filter includes a multiplier and an accumulator which operate 
as an FIR (finite impulse response) filter. Scanline echo signals are shifted sequentially into a multiplier, multiplied by 
coefficients supplied by the coefficient memory 408, and the products are accumulated in the accumulator at the output 
of the multiplier. The coefficients for the filter 412 are chosen to multiply the echo signals by a cosine function and the 

20 coefficients for the filter 41 4 are chosento multiply the echo signals by a sine function, preparatory for I and Q quadrature 
signal detection. The four multiplier filters produce accumulated signals at a rate which is less than the input rate to 
the multipliers, thereby performing decimation band pass filtering. When the signal bandwidth exceeds the display 
bandwidth of the display monitor, the image lines will flicker due to an aliasing condition. The decimation filtering is 
designed to reduce the signal bandwidth as well as the data rate to match the display bandwidth of the monitor. By 

25 applying a succession of input signals and coefficients to a multiplier and accumulating intermediate products, the 
effective length of the filter can be increased. For instance, input signals 1 -8 can be sequentially weighted by the fourth 
multiplier and the products accumulated in the fourth accumulator; input signals 3-10 can be weighted by the third 
multiplier and the products accumulated in the third accumulator; input signals 5-12 can be weighted by the second 
multiplier and the products accumulated in the second accumulator; and input signals 7-14 can be weighted by the 

30 first multiplier and the. products accumulated in the first accumulator. The data rate has thereby been decimated by 
two, and each multiplier and accumulator is effectively operated as an eight tap filter. Thus it is seen that the effective 
number of taps of the filer is a product of the number of multipliers (four in this example) and the decimation rate (two 
in this example). 

Additionally, this filter reduces r.f . noise and quantization noise through its bandwidth limiting effects. I and Q echo 
35 signal samples are produced at the outputs of filters 41 2 and 41 4, amplified if desired by the multipliers of gain stages 
416 and 41 8. then stored in the r.f. memory 420. The Q samples are coupled to the r.f. memory by a multiplexer 426. 

When a synthetic aperture image is to be formed, the I and Q samples from the scanline of the first half of the 
aperture (see the discussion of FIGURE 7 above) are stored in the r.f. memory until the I and Q samples from the other 
half of the aperture are received. As the samples from the second half of the aperture are received, they are combined 
40 with their spatially corresponding counterparts by an adder 424. The size of this memory is kept to a minimum by 
storing the aperture signals after decimation filtering, which reduces the size of the memory required to store the 
scanline signal samples. 

After the I and Q samples for the full aperture have been formed, the echo samples are coupled from the adder 
424 to a detection and compression circuit 428. This circuit includes two shift registers and a multiplier arranged to 

45 form a CORDIC processor for performing envelope detection of the form (I 2 + Q 2 ) 3 *. See, for instance, "The CORDIC 
Trigonometric Computing Technique, by J.E. Voider, IRE Trans, on Elect Computers, (Sept. 1 959). The detected signal 
is compressed and scaled to map the detected signals to a desired range of display gray levels. 

Following detection and compression mapping, the grayscale signals are lowpass filtered in an FIR filter 432, then 
stored in an image frame memory 430. If the selected scanning mode utilizes a single transmit focal point, the grayscale 

so signals are transmitted to the back end ASIC 50 for scan conversion. Prior to leaving the ASIC 40, the greyscale signals 
can be frame averaged by an infinite impulse response (MR) filter 436 which utilizes image frame memory 430 as a 
frame buffer and incorporates one multiplier and two adders to perform frame to frame averaging of the form 

55 . F out= ( 1 " a ) F out-1 + aF new = F ouM + a < F new * F out-l) 

where the multiplier coefficient is a. If the coefficient is a binary number (e.g., 0.5, 0.25, 0.125) F out can be obtained 
with an add-shift-add operation. 
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If multiple focal zones are used, each received scanline segment is stored in the r.f. memory 420 until scanline 
segments from the entire display depth have been received. Preferably the scanline segments for one complete focal 
zone are acquired before transmitting and receiving segments from another focai zone. When all segments for a scan- 
line have been acquired, each complete scanline is then read out of the memory and filtered by the FIR filter 432, 
which smoothes the boundaries between the segments for a more pleasing, artifact-free image. 

If both multiple zone focusing and synthetic aperture are used : the scanline segments of both halves of the aperture 
are received over the full focal zone and assembled in the r.f memory 420. Corresponding scanline segments are then 
received from other focal zones and joined with the segments from the first received focal zone. The completed scan- 
lines are then filtered by FIR filter 432 to smooth the boundaries between segments. 

The user may choose to process the grayscale image with certain image enhancement features, such as depth 
dependent filtering or speckle reduction such as the frequency compounding technique described in U.S. Pat. 
4,561 ,019. These optional processing techniques necessitate the use of the filters 412 and 414 for separate bandpass 
filtering of the scanline signals and absolute value detection rather than quadrature detection. In the case of depth 
dependent filtering the received echo signals are multiplied by cosine functions in both of filters 41 2 and 41 4, but with 
coefficients chosen so that one filter produces output signals in a high passband and the other produces output signals 
in a low passband. The output signals produced by the two filters are of the form \ A = h-, (t)cosco H t and l 2 = h 2 (t)cosco L t. 
These two output signals are amplified in gain stages 416 and 418 by complementary time varying gain control func- 
tions. The high frequency passband signals I-, are initially amplified strongly, then the gain is decreased as echo signals 
are received from increasing depths along the scanline. in a complementary manner the low frequency passband 
signals l 2 are initially at a low level, then amplified in an increasing manner with depth as the high frequency gain is 
rolled off. Thus, signals at shallow depths will exhibit a relatively high passband, and signals from greater depths will 
pass through a relatively lower passband which reduces high frequency noise at the greater depths. Detection in the 
CORDIC processor of circuit 428 is performed by absolute value detection by squaring I-, and l 2 , then summing the 
results. Following summation the signals are log compressed to the desired grayscale mapping characteristic. Alter- 
natively, the signals passed by the separate passbands are summed by the adder 424, then detected by absolute value 
detection in the detection and compression circuitry 428 and mapped. 

The same processors can be used to provide speckle reduction by frequency compounding. The coefficients of 
one of the filters 412,414 are chosen to filter the received signals by a high frequency passband, and the coefficients 
of the other filter are chosen to filter the received signals by a contiguous low frequency passband. The coefficients of 
the gain stages 416,418 are chosen to equalize the responses of the two passbands. The signals of the high and low 
passbands are coupled to the detection and compression circuitry where the passbands are separately detected 
through absolute value detection as described above, then the detected signals are log compressed to the desired 
grayscale mapping characteristic and summed on a spatial basis. 

The processing of Doppier echo signals for power Doppler (CPA) display is shown in FIGURE 8 together with the 
flowchart of FIGURE 1 2. Each scanline vector is scanned repetitively, for instance eight times, to assemble an ensemble 
of Doppler information along the vector. Each received scanline of echo signals is normalized by the normalization 
circuit 410 and undergoes decimation band pass filtering in the filter 412. Each scanline of the ensemble is stored in 
the r.f. memory 420 until a complete ensemble has been accumulated. The scanlines of each ensemble are coupled 
by the multiplexer 422 to the four multiplier filter 41 4, which performs wall filtering and Doppler power estimation through 
matrix filtering. Wall filtering is performed by selection of appropriate multiplier coefficients and the matrix filtering is of 
the form 
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where x-, ... x n are spatially aligned signals from the ensemble of scanlines and y-, ... y n are output Doppler values. In 
a preferred embodiment a four multiplier filter is used for matrix filtering, and the filtering is performed sequentially and 
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incrementally. Intermediate products are accumulated as described above, thereby extending the filter length. For 
example, in processing the above matrix with a four multiplier filter, the intermediate products a^x-, + a 12 x 2 + ^3X3 + 
a 14 x 4 are formed initially and summed in the accumulator Then products a-, 5 x 5 + a 16 x 6 + a 17 x 7 + a 18 x 8 are formed by 
the multipliers and summed in the accumulator'with the previously computed intermediate products. By accumulating 
5 intermediate products in this manner the four multipliers and accumulator can be extended to a filter of any desired 
length, restricted only by the maximum processing time available. The Doppler values are coupled to the detection 
and compression circuitry 428 through the gain stage 41 8 and the multiplexer 426, where the Doppler signal amplitude 
at each echo location along the scanline is detected through absolute value detection of the form 

10 

1-n 

y - 2 y„ J 

n 

15 

The Doppler values y are then compressed and scaled using the CORDIC processor of the detection and compression 
circuitry 428. 

Once the Doppler signal amplitude values have been detected and filtered by FIR filter 432, the resulting values 

20 are spatially stored and image clutter is removed by a flash suppression processor 434, which eliminates large frame 
to frame variations in the displayed signals. A preferred technique for flash suppression processing is min-max filtering 
as shown in the detailed diagram of the flash suppression processor of FIGURE 9. Min-max filtering, a class of mor- 
phological filtering, is performed on temporal signals from a sequence of Doppler image frames. FIGURE 9 illustrates 
the processing of temporal data at a particular sample volume location, with the frame being processed identified as 

25 frame F n .-,. When the Doppler signal from a new frame F n is received, it is compared with the value of the previous 
frame F n _-, and the minimum value of the two is selected by a minimum value selector 630. This minimum value Min-, 
is expressed as Mi^ (F n ,F n-1 ). The minimum value Min-, is compared with the previously selected minimum value Min 2 
(F n-1 F n . 2 ) which is stored in an image buffer A, and the maximum of the two values is selected by a maximum value 
selector 636. The selector 636 therefore selects the maximum of two minimum values, expressed as a min-max value. 

30 The min-max value is subtracted from the Doppler signal value of the current frame F n _., by a subtractor 638. A com- 
parator 640 compares this difference against a signal excursion threshold T. If the difference exceed the threshold T, 
the comparator 640 produces the min-max value for the Doppler signal value of the current frame. If the difference 
does not exceed the threshold T, the current frame value F n _-| is used. When this selection has been made, the Min-, 
value is latched into the image buffer A in place of the previous Min 2 value, new frame value F n is latched into image 

35 buffer B, and the process continues for the other sample volume locations in the current frame, and then the following 
frame. 

This processing may be understood by considering the following sequence (1 ) of Doppler signal values which are 
received over time from a given sample volume location: 

40 

0,1,2,15,7,4,8,5,7,25,8 (1) 

Where the first value 0 is of frame F n and the second value 1 is of frame F n . v When pairs of consecutive values are 
examined for the minimum of the two, the following sequence (2) of minimum values results: 

45 

0,1,2, 15,7,4,8,5,7,25,8 (1) 



50 0,1,2,7,4,4,5,5,7,8 (2) 

This shows that the minimum of the first two values of the sequence (1 ), 0 and 1 , have a minimum value of 0 which is 
the first value in the sequence (2). The second and third values of sequence (1), 1 and 2, have a minimum value of 1 , 
the second value in the sequence 2. The third and fourth values of sequence (1 ), 2 and 1 5, have a minimum value of 
55 2, the third value in the minimum value sequence (2). Sequential values in the minimum value sequence (2) are then 
compared to determine the maximum of the two as shown by the min-max sequence (3): 
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0,1,2,15,7,4,8,5,7,25,8 (1) 



0, 1,2, 7, 4,4, 5,5, 7 : 8 (2) 



1,2,7,7,4,5,5,7,8 (3) 

Thus it is seen that the first two values of the minimum value sequence, 0 and 1 , have a maximum value of 1 , the first 
value in the min-max sequence (3). The minimum values 1 and 2 have a maximum value of 2, the minimum values 2 
and 7 have a maximum value of 7, and so forth. 

From the min-max sequence (3) it is seen that the sudden excursions of the fourth, seventh and tenth values of 
the first sequence, 15, 8, and 25, have been eliminated in the min-max sequence. In the illustrated embodiment the 
difference between the current value and the min-max value is compared to a threshold and the min-max value used 
if the difference exceeds the threshold. In this numerical example this difference is the difference between the first and 
third sequences. If the threshold used is 6, for example, each of the excursions of 15 and 25 would be replaced by 
min-max values in the processor output. The original values would be used in all other cases. 

Min-max processing as described above will follow the received Doppler signals for signal variations within ex- 
pected ranges, but will substitute min-max values to smooth over sudden signal excursions, as shown in FIGURE 1 0. 
FIGURE 10a shows a sequence 650 of signal values at a given location in a Doppler image. The sequence 650 is 
contaminated by sudden excursions 642, 644, and 646, which are artifacts from flash (scanhead movement) or other 
noise sources. The min-max filter of FIGURE 9 will substitute min-max values in place of these undesired excursions, 
as shown by the solid signal sequence 650 below the undesired excursions in FIGURE 10b. With the undesired ex- 
cursions replaced by min-max values, the signal level sequence 650 which is processed for display is as shown in 
FIGURE 10c. A benefit of the min-max processor is that it is effective only for positive excursions. The local peaks and 
valleys which represent the local temporal variations of Doppler power are preserved by this filtering technique. 

The image frame memory 430 is capable of storing either a gray scale frame or a power Doppler frame. Each 
frame can be temporally filtered by the MR filter 436, which performs frame averaging on a point-by-point basis as 
described above. The temporally filtered image information is then provided to the back end ASIC 50 for scan conver- 
sion and display. 

The sequences of operating the digital signal processing ASIC 40 for B mode (two dimensional) echo and Doppler 
processing, respectively, are outlined in the flowcharts of FIGURES 11 and 1 2, respectively. The number in each flow- 
chart block of FIGURES 11 and 1 2 refers to the numbered processor in the ASIC block diagram of FIGURE 8. 

The image frame memory 430 of the digital signal processing ASIC shares a common architecture and implemen- 
tation technology with the frame buffer memory of the back end ASIC discussed below. To take advantage of this 
commonality and the resultant efficiency in ASIC fabrication and density, the image frame memory 430 and its asso- 
ciated flash suppression processor 434 and IIR filter 436 can be located on the back end ASIC 50, thereby partitioning 
the digital signal processing ASIC and the back end ASIC at the output of FIR filter 432. 

Referring to FIGURE 13, the block diagram of the back end ASIC 50 is shown. Processed B mode scanlines 
produced by the digital signal processor ASIC 40 are coupled to a buffer 510 which stores two consecutive scanlines 
for scan conversion. In order to economize on the integrated circuit area, power requirements : and heat dissipation 
needed for the scan conversion function, a straightforward linear interpolation algorithm and simple conversion tech- 
nique requiring only adders and accumulators for addressing are employed. In the case of the use of a curved array 
transducer 10 as shown in FIGURE 1 , the scanned sector 560 as shown in FIGURE 14 is scan converted in the following 
manner. In FIGURE 1 4 the radial scanlines of sector 560 are converted to the x.y coordinates of a frame buffer memory 
530 of FIGURE 1 3, the boundaries of which are defined as D x and D y in FIGURE 14. The radial scanlines of the sector 
560, one of which is shown at vector V, emanate from the virtual apex point 564. With a curved array there are no data 
points between the virtual apex and the skinline (transducer location) 562, although with a phased array scanhead the 
apex would be in the D x ,D y image area In the case of a linear array there is no apex, and the parallel scanlines and 
interpolated lines are simply recorded into the frame buffer memory 530. The following example describes scan con- 
version of the most complex of the arrays for scan conversion, the curved array 1 0. From this example scan conversion 
with other array formats will be apparent. 

In FIGURE 1 4 the scanlines are defined by polar R.Gcoordinates, which are to be converted to the x s ,y s coordinates 
of the display screen. The polar coordinates have an origin at apex point 564, whereas the screen coordinates have 
an origin (0,0) at the top center of the display area. The screen coordinate origin is offset from the apex by the distance 
y 0 in the y direction, and is at the top center of the D x ,D y image area. In the case of the curved array, there are no valid 
data points along the initial radius of curvature segment R oc of each vector V. Beyond the initial distance R^ (which 
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is below the skinline 562) valid echo data exists and will be located to the proper address in the scan converter memory 
530. The dot at the end of vector V in FIGURE 1 4, for instance, has polar coordinates of R.9 which are to be converted 
to screen coordinates x s ,y s and located at that address of the scan converter memory. 

Prior to scan conversion the two scanlines stored in the two line buffer 510 are used to interpolate a number of 

s interlineated scanlines. A linear interpolation scheme aL, +(1 -a)L 2 as shown in FIGURE 1 5 has been found to produce 
satisfactory results. The preferred implementation expression is Lg + a(L,-L 2 ) which requires only a single multiplier. 
In the example of FIGURE 15, seven scanlines are interpolated between each pair of received scanlines L| and L 2 . 
The illustrated scanline L t is at the radial boundary of the sector 560. Interpolated scanlines radially outward from this 
boundary scanline (to the left in the drawing) are produced by weighting the data values on scanline by weights of 

10 7/8, 3/4, 5/8, 1/2, 3/8. 1/4, and 1/8 as shown to the left of scanline L, in FIGURE 15. Between scanline pairs the 
interpolated scanlines are weighted combinations of both Lj and L 2 , as shown by the weighted values of 7/8L,+1/8L 2 , 
3/4^+1/41-2 ancl so f ort h. Interpolation is done by taking a data value along the scanline such as R t> weighting it by a 
weighting factor such as 7/8, then adding it to a complementary weighted, spatially corresponding data point R n from 
the next scanline. Interpolation in this manner proceeds down the scanline until finished, then the next scanline is 

is interpolated. As interpolated scanlines are produced they are immediately placed in the frame buffer memory 530. 

FIGURE 13 shows the two line buffer 510 which holds the two scanlines L-, and L 2 while the line interpolator 512 
uses the buffered scanlines to produce interpolated scanlines. Weights for the interpolation process are provided by 
the line interpolation weighting store 522 of the scan conversion controller 520. When the intervening interpolated lines 
have been produced, the oldest scanline in the two line buffer 510 is replaced by a new adjacent scanline. Since the 

20 locations which store the two scanlines in the buffer 510 are updated alternately, the weights used for the retained 
scanline are simply used in the next interval in the reverse order. In FIGURE 15 it is seen, for example, that scanline 
L 2 is weighted in the interval between lines L, and L 2 with weights increasing from 1/8 to 7/8. After line L n is replaced 
with the next line L 3 , scanline is weighted in the reverse order, declining from 7/8 to 1/8 in the following interval. 
This avoids the need to move the retained scanline from one area to another in buffer 510; it is only necessary to 

25 replace the oldest scanline with a new one. 

It follows that the received scanlines are passed through the line interpolator 51 2 without change at the appropriate 
times in the scanline sequence. 

As scanlines are produced at the output of the line interpolator 512 their data values are scan converted to the 
storage locations in the frame buffer memory 530 in the following manner. The polar coordinates of the radial scanlines 

30 are related to the rectangular coordinates of the memory 530 by 

x - RsinG 

35 and 

y = RcosG 

40 where R is the radial distance along a vector extending at an angle 0 with respect to the y axis in FIGURE 1 4. Solving 
for R and then substituting the solution for R in the expression for x yields 

R = y/cosO 

45 

and 

x = ytan9 

50 

These expressions are used to increment values in the R, x s , and y s accumulators to provide simple scan conversion 
addressing. 

As the line interpolator begins outputting a scanline, the scanline data from selected R addresses along the scanline 
are stored in the frame buffer memory 530 at x SJ y s addresses. Data storage starts at the first row (y=1 ) of the memory 
55 area D x ,D y , and proceeds sequentially down the rows of the memory. Thus, the y s accumulator simply accumulates 
integer values starting at 1 . The R accumulator is initialized to a value of y 0 cos8, which offsets the first scanline address 
from the apex of the scanlines to the sample of the scanline which is aligned with the first row of the memory in FIGURE 
14. The x s address for the memory 530 is initialized to a value of y 0 tan8, the point along the first row of the memory 
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which intersects the R,8 vector V in FIGURE 14. The y 0 values forthe initialization values are provided by an initialization 
storage device 526. 

From these starting address values the R accumulator which addresses the line interpolator 512 is incremented 
by a constant 1/cosB to sequentially step from one R,B scanline value which is to be stored to the next. The y s accu- 
mulator which addresses the frame buffer memory 530 is incremented by integer values and the ^ accumulator for 
the memory 530 is incremented by a constant 1/tan9 to step to each new storage address of the frame buffer memory. 

Two further steps are involved in the scan conversion process. One is a check of the R addresses against a 
constant for the scanline which accounts forthe radius of curvature R^of the transducer array. As FIGURE 14 shows, 
the boundary scanlines at the outermost periphery of the sector 560 start from the top row of the D x ,D y display area, 
but all other scanlines of the curved array start below the top due to the curvature of the array. To account for this, an 
offset due to the curvature is calculated for each scanline in units of the R address. As the R address accumulator 
produces its initial R addresses they are compared with the calculated R oc offset. R addresses produced by the R 
address accumulator are ignored until the first R address which exceeds Rq C from which point data values of the 
scanline are stored in the memory 530. 

Another step which is performed before scanline data values are written into the selected address locations of the 
memory 530 is to check whether a data value was previously written to the selected address location. A one bit map 
of bits b e corresponding to address locations in the frame buffer memory is used as each image frame is scan converted. 
When a new data value is written to a location in memory, the corresponding bit b e for that address location is set, 
indicating that a data value has been entered into memory for that frame. If scan conversion of another scanline during 
that frame addresses the same memory location, the b e bit tells the write controller 528 that a data value has already 
been entered at that location for that frame. This will cause the write controller to cancel entry of the new data value, 
or overwrite the previously stored data value, depending upon the protocol chosen by the user or the scan controller 
designer The scan converter may utilize a protocol which replaces previously entered data values with new ones, or 
only enters the first data value and ignores all later values. Another protocol is to overwrite old values with new ones 
as scanlines proceed from the periphery to the center of the image, then to enter the first value found and reject 
subsequent values for scanlines proceeding from the center of the image to the periphery. In a preferred embodiment 
the protocol is simply to enter the first data value for each memory location, and ignore subsequent attempts to overwrite 
the location with new data. 

When ail scanlines have been written into the memory 530, the map of b e bits contains all ones. During the next 
image frame these bits are inverted to zeroes as data values for the new frame are written to the storage locations of 
the memory. Thus, there is no need to reset the b e bit map between frames; complementary b e bit values are used to 
map data entries for successive image frames. 

The operation of the scan conversion process is illustrated in FIGURE 16, where two scanline vectors V 0O and 
v 645 are seen extending from the curved transducer array 1 0. A matrix of blocks is shown to spatially represent memory 
locations in the scan converter buffer memory 530. The scanline V 90 extends from the center of the array and is or- 
thogonal to the memory matrix and is identified as extending at an angle 9 = 0°. When the scanline data samples have 
been bandlimited in the digital signal processing ASIC 40 as described above, the detected samples along the scanline 
vector will fall sequentially into consecutive memory locations in a column of the memory 530. This is shown by con- 
secutive scanline R values F^, R3, R4, R5 and R 6 at consecutive y addresses 2 through 6. If the scanline data has not 
been bandlimited to match the bandwidth of the display, a number of intermediate samples will be skipped as the R 
address accumulator 524 is incremented from row to row. The scanline data pan thus be scaled during scan conversion 
if it has not been scaled earlier in its processing. 

The other scanline at vector extends at an angle of 45° with respect to the first vector. At this angulation it is 
seen that there are more samples than blocks (locations) in the memory matrix along the scanline vector. The rows of 
the memory matrix are addressed in integer values of y from 2 through 6 over the scanline interval shown in the drawing. 
The x addresses of the memory are incremented by the constant of ytanG for each row y, using the tangent of the 
scanline angle, tan 45°. This results in a sequence of x addresses of 7 through 11 for the portion of the V 045 scanline 
shown in the drawing. The R addresses along the scanline are incremented by the constant y/cos9 as described above, 
and fractional amounts are truncated to yield the selected R addresses shown by the solid circles. It is seen that the 
R 4 value is not used, and R values of R 5 and R 6 are stored at x,y addresses of 7,2 and 8,3. The R 7 value is skipped 
and the next three R values, R 8 , R 9 , and R 10 are stored in rows 4, 5, and 6. The next R value, R 11( is skipped before 
a scanline value is stored in the next row. It has been found that truncation of the fractional portion of the R value will 
choose the most accurate scanline R value, that is, within a one pixel tolerance, for each location in the scan converter 
memory. 

Each memory location in the frame buffer memory 530 stores a data value from a received or interpolated ultrasonic 
scanline and two additional bits. Of these two additional bits, one is set to identify the stored data value as either a 
black and white or a color data value; a 0 identifies the data value as a black and white pixel, and a 1 identifies the 
data value as a color pixel. When this bit is set for a color pixel, the data value at the pixel accesses a color map look- 
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up table 532 : which selects the proper red (R), green (G), and blue (B) signal values for display. A 0 value results in 
display of the data value as a gray level pixel. The second additional bit, as described above, is the be bit which maps 
the entries of data values into memory for each image frame. The b e bit is read by the write control circuit 528 to 
determine whether a new data value is to be written to memory in accordance with the protocol used by the scan 
5 converter. 

The scan converted frame in buffer memory 530 is read from the memory after the frame has been assembled. 
Color pixels look up R, G, and B values in the color map look-up table 532, which are then passed to a video processor 
550. Grayscale pixels are passed directly to the video processor. In the video processor, the ultrasonic image is overlaid 
with graphics from the graphics overlay buffer 540. This graphic information can comprise time, date, patient identifi- 

10 cation, scale markers, Doppler window outlines, cursors, and other graphical information useful to the user. The ultra- 
sound image and its graphical information may then be produced as an output signal for a display. A variety of output 
signal formats are possible, including NTSC video format, PAL format, or RGB format. The output signals are produced 
at a digital to analog converter output of the video processor 550 and may be baseband or modulated carrier signals. 
The signals may drive the unit's own LCD display 60, or are produced at an output terminal for a separate, external 

15 monitor. The unit includes a video memory 552 for Cineloop storage and replay of a real time image sequence desig- 
nated by the user for storage and replay. 

The ultrasound image produced by the handheld system may be a B mode grayscale image, a power Doppler 
image, a combination of grayscale and power Doppler image information, or a three dimensional power Doppler image. 
When a combined grayscale and power Doppler image is produced, the user will designate a subsector window within 

20 the full sector over which power Doppler signals will be gathered and displayed. Such a subsector 602 is shown as a 
shaded subsector in the sector 600 of FIGURE 17. The subsector 602a may extend completely from the top to the 
bottom of the sector 600, as shown in FIGURE 1 7a, in which case the subsector scanlines will be power Doppler lines, 
and the scanlines on either side of the subsector 602a, such as the groups of lines indicated at 604, are produced as 
grayscale lines. In the preferred embodiment the height of the power Doppler subsector window is also controllable 

25 by the user to allow the subsector to be bordered on all sides by grayscale image information, as shown by subsector 
602b in FIGURE 1 7b. Moreover, the power Doppler information is blended with B mode grayscale information over the 
area of the subsector window. This is shown in FIGURE 18 with reference to FIGURE 13. As scanlines of power Doppler 
information over the subsector area are received, the power Doppler signals are stored in a 3D power Doppler memory 
502. When scanlines of B mode data are received which overlap the subsector, those scanlines are applied to a blending 

30 circuit 504. The spatially coincident power Doppler signals are applied to the blending circuit at the same time, and 
scanline data which is a blend of both power Doppler and grayscale information is produced by blending the data 
together. Two such received and blended scanlines are shown in FIGURE 18 as scanlines Bj and Q hv As these lines 
shown, the top (near field) portion 610 of each line and the lower (far field) portion 612 of each line comprises only 
grayscale data In the intermediate portion 614 of each received line, grayscale and power Doppler information is 

35 blended together. For instance, if power Doppler information is to be displayed in a solid red color and grayscale 
information is to be displayed as different brightness levels, the blending of these two types of information could result 
in a bright red color, a dimly red color, a light pink color, or other combination of a measured variation of the color red 
and a level of brightness. As received scanline information is blended, the blended lines are provided to the two line 
buffer 510 for interpolation of intermediate scanlines and scan conversion. Interpolated lines such as interpolated 

40 scanline 620 are produced intermediate the two received scanlines in the manner shown in FIGURE 15. Thus, the 
blended region of each line, when the lines are scan converted and displayed adjacent to each other, will convey 
information on both the blood flow and the tissue structure of the region of the body depicted in the power Doppler 
subsector 602. 

One image boundary refinement is worth noting. To correctly fill the image area when the Doppler scanline infor- 
ms mation is overlaid on the grayscale scanline information, the beginning of the Doppler information area should be 
overlaid on top of the last grayscale line. As the Doppler scanline area is completed the last Doppler scanline is overlaid 
by the first scanline of the remainder of the grayscale portion of the image. 

The handheld ultrasound system of the present invention is also capable of presenting power Doppler images in 
a three dimensional projection view format. For three dimensional presentation, a sequence of spatially consecutive 
so and approximately parallel power Doppler image frames are scanned and the received scanlines are stored in the 3D 
power Doppler memory 502. The frames in the sequence are not scan converted individually and saved, for this would 
require a considerable storage area for the scan converted images with their interpolated scanlines. Instead, the scan- 
lines of the sequence of frames are scan converted repetitively for each viewing angle of the three dimensional pro- 
jection image. As each frame is scan converted it is immediately rendered into the three dimensional display. The 
55 frames of received scanlines are repetitively scan converted and rendered into three dimensional images of incremen- 
tally different viewing angles to present a three dimensional image of a volume of the body which appears to be rotating 
about one or more of its axes. 

By way of example, suppose that six parallel image frames are acquired at incrementally increasing depths in the 
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z direction. FIGURE 19 illustrates these image frames when aligned in parallel with the z dimension extending into the 
drawing. The image frames therefore are fully aligned so that only the top image frame 700 is visible; the other image 
frames 702-71 0 are behind image frame 700. Each image frame includes an image sector 71 2, one of which is visible 
on top in FIGURE 19. 

5 Now suppose that the image frames 700-710 of FIGURE 19 are rotated about a centroid y axis, as shown in 

FIGURE 20. The edges of the obscured frames 702-710 now become visible by reason of the rotation. The rotation 
shifts the orientation of the z axis to a rotated direction Zq. In a handheld ultrasound system of the present invention a 
three dimensional projection image is formed of this rotated image set, projected as if the viewer is viewing the image 
planes through a viewing window 720 and at a viewing angle 722. It is seen that the sector 71 2 has become compressed 

10 in its x dimension when rotated, as shown by sector 71 2 in FIGURE 20, which permits the scan conversion techniques 
of U.S. Pat. 5,485,842 to be employed to render a three dimensional presentation. In accordance with the present 
invention, the three dimensional rendering is done by addressing the planar frame data through efficient accumulation 
of address constants in accumulators. 

For ease of illustration an example of three dimensional processing will be given for rotation about the y axis. This 

75 means that a scan converted image will have the same y row coordinates when the image frame set is rotated by an 
angle 9, or y e = y. The other coordinates are expressed in matrix form as: 



20 



cos9 sin0 



-sin0 cosG 



(4) 



x - x cd 



25 



where z e and x 9 are the x and y coordinates in the 9 rotated coordinate system, z is the number of an image frame in 
the sequence, x c6 is the centroid of the image frame set in the viewing window 720, and x^ is the center of a particular 
image frame. Solving for x yields 



30 



x = — ^ + x cd + ztan9 

cos 9 cd cos 9 



(5) 



of which the latter three terms are constants used to initialize the x address for three dimensional projection. 

The received scanlines from a Doppler image frame are scan converted as described previously, and the scan 

35 converted and interpolated planar image is projected into a 3D buffer which stores the three dimensional projection 
image. The pixels in the scan converted image are processed row by row and pixel by pixel to project the Doppler 
values to their positions in the three dimensional image presentation. Rows of both the planar image and the 3D buffer 
are sequentially addressed by a y address accumulator that simply accumulates integers to sequentially process image 
row 1, image row 2, and so forth. The x addresses of the 3D buffer are incremented across each row in integer form 

40 by a counter which counts in the sequence 1 , 2, 3, and so forth. 

The x addresses of the planar image start from an initial value formed by the latter three constant terms of expres- 
sion (5). Each projection image of the 3D buffer exhibits a different projection angle 9, and thus a constant value of 
tan9 is calculated and used for processing of a projection image. The center of the 3D image centroid x^ is a known 
constant for a given 3D projection image sequence and the center of each planar image x^ is a known constant for 

45 each planar image. Thus, from expression (5), the x address for converting the planar image starts from 



so 



* ini , = x cd -^ e+ ztane < 6 > 



The x jni! value for a given planar image and given viewing angle 9 is calculated and stored, and used to initialize the 
first x address location in each row y of the planar image. Successive addresses are produced from this initial x address 
by adding the constant value of 1/cos9 to the previous address, and relocating each addressed value of the planar 
image to successive x address locations across each row of the three dimensional projection image. As each row is 
55 finished, the y row address is incremented by one, the x address of the planar image is reinitialized to Xj nit , and the 
process continues down each row of the planar image until the complete image has been relocated to the projection 
image. 

After one planar image has been relocated to the projection image, the value of ztan9 is incremented to the next 
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z value. Thus, the sequence of ztanG values will proceed from tan9 to 2tan0 to 3tan0 and so forth through the sequence 
of planar images. Each new ztanG value is used in the calculation ol a new x init value for the next planar image in the 
sequence in accordance with expression (6). 

There are a number of ways of combining the planar image information in the projection image. One technique is 

s the maximum intensity technique whereby, if a value from a previous planar image has already been stored in the 
projection image locatioa the next value to be stored in the same location is compared with the previously stored value. 
The greater of the two values is then stored. Thus, the projection image will contain the maximum intensity value at 
each location in the rendered projection image. 

A second combining technique which imparts a semi transparent characteristic to the projection image is an av- 

io eraging technique. Each new value for a given projection image location is averaged with the values prevbusly stored 
at the location, so that the resultant image reflects not the maximum intensity, but an average through the planar image 
set. Depending upon whether the planar image processing proceeds from the front or the back image of the set, the 
projection image will be weighted in favor of the planar images closest to the viewer, or in favor of the planar images 
most distant from the viewer, or the values can be weighted in accordance with the distance of their z value from the 

is viewing window 720. The technique chosen by the viewer is one of personal preference. 

The foregoing three dimensional presentation technique advantageously conserves memory by storing only re- 
ceived scanlines. There is no need to expend storage on a full interpolated image set, as interpolation is performed 
as each projection image is formed. The inventive technique utilizes efficient addressing by simple incrementing of 
address accumulators with constant values for each projection image. 

20 a preferred implementation of three dimensional imaging in accordance with the present invention makes efficient 

use of the frame buffer memory 530 by partitioning the memory into four quadrants as shown in FIGURE 21. For 
instance a first frame of received scanlines is interpolated and scan converted into the memory area identified as B1 . 
The scan converted first planar image in area B1 is relocated to three dimensional projection coordinates in the memory 
area identified as A1 . While this three dimensional projection of the first planar image is taking place, the second frame 

25 of received scanlines is interpolated and scan converted into the memory area B2. Then, while the scan converted 
second planar image in area B2 is projected to the projection coordinates in area A1, the third frame of received 
scanlines is scan converted into the B1 memory area Memory areas B1 and B2 are alternatively used by consecutive 
image frames until the full projection image has been formed in the A1 area. 

The projection image in the A1 area is then read out line by line for video display. As the A1 projection image is 

30 read out, memory areas B1 and B2 again scan convert the received frames in alternate fashion and a second projection 
image at the next viewing angle G is assembled in the A2 memory area. After the first projection image has been 
displayed from the A1 memory area and the second projection image at the next projection angle has been fully as- 
sembled in the A2 memory area, the second projection image is read out from area A2 and displayed. The process 
continues with areas B1 and B2 scan converting the received frames to form a third projection image at a third projection 

35 angle in the A1 memory area. Thus, all four quadrants of the buffer memory are interactively used to efficiently produce 
a three dimensional projection which appears to rotate about the y axis before the viewer. 

For rotation about two axes simultaneously, a second projection of the planar images must be performed to rotate 
the coordinates from an intermediate coordinate system 9 to a final coordinate system <p. For example, after the planar 
image set has been rotated about the y axis by an angle 0, the image coordinates can be translated a second time by 

40 rotation through an angle <p about the x axis. For the second coordinate transformation x^ is set equal to x e , the value 
of z in matrix expression (5) is set to z e , and z e on the left side of the matrix is set to z^. The matrix expression is solved 
for y and the second coordinate transformation performed to the twice rotated coordinate values. The second trans- 
formation of coordinates required for each planar image for each projection image will increase the time required to 
produce the three dimensional presentation. 

45 it will be appreciated that there is no need to perform coordinate transformation on pixels outside the area of sector 

712 in each planar image. Since the sector area should be identical from one scan converted image to another and 
occupy known coordinates in each image, it is possible to improve processing speed by only converting and projecting 
image information within the sector area. 

The back end ASIC 50 is the location of the RISC processor 500, which is used to coordinate the timing of all of 

50 the operations of the handheld ultrasound system. The RISC processor is connected to all other major functional areas 
of the ASICS to coordinate processing timing and to load buffers and registers with the data necessary to perform the 
type of processing and display desired by the user. Program data for operation of the RISC processor is stored in a 
program memory 52 which is accessed by the RISC processor. Timing for the RISC processor is provided by clock 
signals from the clock generator on the front end ASIC 30. The RISC processor also communicates through a PCMCIA 

55 interface, by which the processor can access additional program data or transmit image information remotely. The 
PCMCIA interface can connect to a telemetry link or a modem for the transmission of ultrasound images from the 
handheld unit to a remote location, for instance. 

The RISC processor is operated under user control by commands and entries made by the user on the user control 
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70. A chart showing control functions, the type of controls, and their description is shown in FIGURE 22. It will be 
appreciated that a number of functions, such as patient data entry, Cineloop operation, and 3D review, will operate 
through menu control to minimize the number of key or button controls on the small handheld unit. To further simplify 
the unit a number of operating functions are preprogrammed to specific diagnostic applications and will operate auto- 
matically when a specific application is selected. Selection of B mode imaging will automatically invoke frequency 
compounding and depth dependent filtering, for instance, while a four multiplier filter will automatically be set up as a 
wall filter when Doppler operation is selected. The menu selection of specific clinical applications can automatically 
invoke specific feature settings such as TGC control characteristics and focal zones, for example. 



Claims 



1. A portable ultrasound system comprising: 

an array transducer; and 

a beamformer for delaying and combining echo signals received by elements of said array transducer, 
wherein said array transducer and said beamformer are located in a common enclosure. 

2. The portable ultrasound system of Claim 1 , wherein said array transducer is a linear array. 

3. The portable ultrasound system of Claim 1 , wherein said array transducer is a curved linear array 

4. The portable ultrasound system of Claim 1 , wherein said beamformer is a digital beamformer which delays and 
combines digital echo signals. 

5. A handheld ultrasound system comprising: 

an array transducer; and 

a beamformer for delaying and combining echo signals received by elements of said array transducer, 
wherein said array transducer and said beamformer are located in one or more enclosures weighing less than 
ten pounds (4.5 kilograms). 

6. The handheld ultrasound system of Claim 5, further comprising a digital filter coupled to the output of said beam- 
former and located in the same enclosure as said beamformer. 



7. The handheld ultrasound system of Claim 5, further comprising an image processor coupled to the output of said 
digital filter and located in the same enclosure as said digital filter. 

8. The handheld ultrasound system of Claim 7, further comprising an image display coupled to the output of said 
image processor. 

9. The handheld ultrasound system of Claim 8, wherein said beamformer, said digital filter, and said image processor 
are located in a first enclosure, and said image display is located in a second enclosure. 

10. The handheld ultrasound system of Claim 5, wherein said beamformer is a digital beamformer which delays and 
combines digital echo signals. 

11. The handheld ultrasound system of Claim 10, further comprising a digital filter and an image processor located in 
a common enclosure with said digital beamformer. 

12. The handheld ultrasound system of Claim 11 , wherein said image processor includes a digital scan converter. 

13. A handheld ultrasound system comprising: 



a transducer; 

a B mode signal processor; and 
a Doppler signal processor, 

wherein said B mode signal processor and said Doppler signal processor are located in a common handheld 
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enclosure. 

14. The handheld ultrasound system of Claim 13, wherein said common handheld enclosure weighs less than ten 
pounds (4,5 kilograms). 

5 

15. The handheld ultrasound system of Claim 14, further comprising a digital beamformer located in said common 
handheld enclosure. 
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